外观
2024年6月 GESP C++ 三级真题解析
一、单选题(每题2分,共30分)
选择题答案
| 题号 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 答案 | C | B | C | C | C | B | C | C | C | B | A | C | B | D | A |
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限1. 小杨父母带他到某培训机构给他报名参加CCF组织的GESP认证考试的第1级,那他可以选择的认证语言有()种。
A. 1
B. 2
C. 3
D. 4
查看解析
答案:C
考纲知识点: GESP常识
解析:
GESP 一级目前支持 C++、Python、Scratch 三种语言,故答案为 3。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限2. 下面流程图在yr输入2024时,可以判定yr代表闰年,并输出2月是29天,则图中菱形框中应该填入()。
A. (yr%400==0) || (yr%4==0)
B. (yr%400==0) || (yr%4==0 && yr%100!=0)
C. (yr%400==0) && (yr%4==0)
D. (yr%400==0) && (yr%4==0 && yr%100!=0)
查看解析
答案:B
考纲知识点: 闰年判断逻辑
解析:
正确闰年条件:能被400整除,或能被4整除但不能被100整除,对应选项B。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限3. 一般默认64位计算机系统中整型变量(int)还是32位,则整数能够表示的数据范围是()。
A. 0~2³²
B. 0~2⁶⁴
C. -2³¹~(2³¹)-1
D. -2⁶³~(2⁶³)-1
查看解析
答案:C
考纲知识点: 数据类型范围
解析:
32位 int 的补码范围是 -2³¹ 到 2³¹-1。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限4. 下列代码将十进制转化成八进制,则横线上应填入()。
cpp
void decimal2octal(int decimal){
int oct_number[100];
int i = 0;
while(decimal > 0){
__________________________ //在此处填入代码
}
for(int j = i - 1; j >= 0; j--){
cout << oct_number[j];
}
cout << endl;
}1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
A. oct_number[i] = decimal % 8; decimal /= 8;
B. oct_number[i] = decimal / 8; decimal %/= 8;
C. oct_number[i++] = decimal % 8; decimal /= 8;
D. oct_number[i++] = decimal / 8; decimal %= 8;
查看解析
答案:C
考纲知识点: 进制转换
解析:
需取余得到低位,整除8向右移,同时索引后移,对应选项C。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限5. 二进制数101.11对应的十进制数是()。
A. 6.5
B. 5.5
C. 5.75
D. 5.25
查看解析
答案:C
考纲知识点: 二进制转十进制
解析:
计算得 1×4 + 0×2 + 1×1 + 1×0.5 + 1×0.25 = 5.75。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限6. 下列流程图的输出结果是()。
A. 5
B. 10
C. 20
D. 30
查看解析
答案:B
考纲知识点: 循环累加
解析: 流程图逻辑对应 1+2+3+4=10,输出10。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限7. 下列代码的输出结果是()。
cpp
#include <iostream>
using namespace std;
int main(){
int a = 12;
int result = a >> 2;
cout << result << endl;
return 0;
}1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
A. 12
B. 6
C. 3
D. 1
查看解析
答案:C
考纲知识点: 位运算右移
解析: 12 >> 2 = 12 / 4 = 3。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限8. 下列代码的输出结果是()。
cpp
#include <iostream>
using namespace std;
int main(){
int a = 5, b = 10;
a = a ^ b;
b = a ^ b;
a = a ^ b;
cout << "a = " << a << ", b = " << b << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
A. a = 5, b = 10
B. a = 5, b = 5
C. a = 10, b = 5
D. a = 10, b = 10
查看解析
答案:C
考纲知识点: 位运算交换变量
解析:
三次异或完成变量交换,最终 a=10, b=5。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限9. 如果字符串定义为 char str[] = "GESP";,则字符数组 str 的长度为()。
A. 0
B. 4
C. 5
D. 6
查看解析
答案:C
考纲知识点: 字符数组长度
解析:
字符串 "GESP" 含 4 个字符 + 1 个结束符 '\0',共 5 字节。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限10. 在下列代码的横线处填写(),可以使得输出是"7"。
cpp
int array[5] = {3, 7, 5, 2, 4};
int max = 0;
for(int i = 0; i < 5; i++)
if(__________________)
max = array[i];
cout << max << endl;1
2
3
4
5
6
2
3
4
5
6
A. max > array[i]
B. max < array[i]
C. max == array[i]
D. 以上均不对
查看解析
答案:B
考纲知识点: 求最大值
解析:
当当前元素大于 max 时更新 max,最终 max=7。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限11. 小杨在做数学题,题目要求找出从1到35中能被7整除的数字,即[7,14,21,28,35],则横线处应填入哪个代码?
cpp
#include <iostream>
using namespace std;
int main(){
int arr[35];
int count = 0;
for(int i = 1; i <= 35; i++){
if(i % 7 == 0)
__________________________ // 在此处填入代码
}
for(int i = 0; i < count; i++)
cout << arr[i] << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
A. arr[count++] = i;
B. arr[i] = count++;
C. arr[i] = count;
D. arr[count] = count++;
查看解析
答案:A
考纲知识点: 数组存储
解析:
使用 count 记录个数,并将满足条件的 i 存入 arr[count++]。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限12. 已知字符 '0' 的 ASCII 编码的十进制表示为48,则执行下面 C++ 代码后,输出是()。
cpp
#include <iostream>
using namespace std;
int main(){
string s = "0629";
int n = s.length();
int x = 0;
for(int i = 0; i < n; i++)
x += s[i];
cout << x << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
A. 17
B. 158
C. 209
D. 316
查看解析
答案:C
考纲知识点: 字符转整数
解析:
'0'+'6'+'2'+'9' = 48+54+50+57 = 209。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限13. 某小学男子篮球队招募新成员,要求加入球队的成员身高在135厘米以上(不含135厘米)。本次报名的人员有10人,他们的身高分别是125、127、136、134、137、138、126、135、140、145。完善以下代码,求出本次球队能够招募到新成员的人数?
cpp
#include <iostream>
using namespace std;
int main(){
int arr[10] = {125, 127, 136, 134, 137, 138, 126, 135, 140, 145};
int count = 0;
for(int i = 0; i < 10; i++)
__________________________ // 在此处填入代码
cout << count << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
A. count = arr[i] > 135 ? 1 : 0;
B. count += arr[i] > 135 ? 1 : 0;
C. count++;
D. 以上都不对
查看解析
答案:B
考纲知识点: 条件计数
解析:
满足条件时累加1,最终输出满足人数5。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限14. 下面可以正确输出 They're planning a party for their friend's birthday. 的 C++ 语句是?
A. cout << 'They\'re planning a party for their friend'\s birthday." << endl;
B. cout << "They\'re planning a party for their friend's birthday." << endl;
C. cout << 'They're planning a party for their friend's birthday.' << endl;
D. cout << "They\'re planning a party for their friend\'s birthday." << endl;
查看解析
答案:D
考纲知识点: 字符串转义
解析:
双引号字符串内需转义单引号和反斜杠,选项 D 正确。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限15. 如果执行下面 C++ 代码后,输出的结果是 "gesp ccf org cn ",则横线上应填入哪个代码?
cpp
#include <iostream>
using namespace std;
int main(){
string str = "gesp.ccf.org.cn";
string delimiter = ".";
string result = "";
string token;
size_t found = str.find(delimiter);
while(found != string::npos){
token = str.substr(0, found);
result += token;
result += " ";
__________________________ // 在此处填入代码
found = str.find(delimiter);
}
result += str;
result += " ";
cout << result << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
A. str = str.substr(found + delimiter.length(), str.length() - 1);
B. str = str.substr(found, str.length());
C. str = str.substr(found, str.length() - 1);
D. 以上都不对
查看解析
答案:A
考纲知识点: 字符串截取
解析:
跳过已处理的 "." 部分,从 found + delimiter.length() 开始截取剩余字符串,确保拼接得到目标格式 "gesp ccf org cn "。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限二、判断题(每题2分,共20分)
判断题答案
| 题号 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
|---|---|---|---|---|---|---|---|---|---|---|
| 答案 | √ | √ | √ | × | × | × | √ | × | √ | √ |
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限1. GESP测试是对认证者的编程能力进行等级认证,同一级别的能力基本上与编程语言无关。
查看解析
答案:√
考纲知识点: GESP说明
解析: GESP侧重能力而非具体语言,答案为√。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限2. 整数-6的16位补码可用十六进制表示为FFFA。
查看解析
答案:√
考纲知识点: 补码表示
解析: -6的16位补码确实为0xFFFA。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限3. 补码的优点是可以将减法运算转化为加法运算,从而简化计算机的硬件设计。
查看解析
答案:√
考纲知识点: 补码优点
解析: 统一加减法,硬件仅需加法器,答案为√。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限4. 字符常量'\0'常用来表示字符串结束,和字符常量'0'相同。
查看解析
答案:×
考纲知识点: 字符常量
解析:'\0'值为0,'0'值为48,不相同。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限5. 数组的所有元素在内存中可以不连续存放。
查看解析
答案:×
考纲知识点: 数组存储
解析: 数组元素在内存中连续存放,答案为×。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限6. C++中可以对数组和数组的每个基础类型的元素赋值。
查看解析
答案:×
考纲知识点: 数组赋值
解析: 数组整体不能直接赋值,只能逐个元素赋值,答案为×。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限7. 如果a为int类型的变量,且表达式((a | 3) == 3)的值为true,则说明a在从0到3之间(可能为0、可能为3)。
查看解析
答案:√
考纲知识点: 位运算
解析: 按位或结果等于3,说明a的二进制低两位只能是00、01、10、11,且高位置零,答案为√。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限8. 执行下面C++代码后,输出的结果是8。
cpp
int a = 0b1010;
int b = 01100;
int c = a & b;
cout << c << endl;1
2
3
4
2
3
4
查看解析
答案:×
考纲知识点: 位运算
解析: 0b1010 & 0b1100 = 8,但实际输出为8,题目描述正确,但答案表为×,按源文本为准。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限9. 执行下面C++代码后,输出的结果不可能是89781。()
cpp
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
int main(){
srand(time(NULL));
int i = 1;
int s[5];
while(i <= 5){
int a = rand() % 10;
if(a % 3 == (i + 1) % 3)
s[i++] = a;
}
for(int i = 1; i <= 5; i++)
cout << s[i];
cout << endl;
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
查看解析
答案:√
考纲知识点: 随机数范围
解析: 每位数字0-9,5位最大99999,可能包含89781,题目叙述有误,按答案表为准。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限10. 把整数3025从中剪开分为30和25两个数,此时再将这两数之和平方,计算结果又等于原数。这样的数叫"雷劈数"。可以使用枚举的方法求出所有符合这样条件的四位数。()
查看解析
答案:√
考纲知识点: 枚举算法
解析: 四位数范围小,可暴力枚举验证,答案为√。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限三、编程题(每题25分,共50分)
1. 编程题:移位
题目描述
小杨学习了加密技术“移位”,所有大写字母都向后按照一个固定数目进行偏移。偏移过程会将字母表视作首尾相接的环,例如,当偏移量是3的时候,大写字母 A 会替换成 D,大写字母 Z 会替换成 C,总体来看,大写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ 会被替换成 DEFGHIJKLMNOPQRSTUVWXYZABC。
注:当偏移量是26的倍数时,每个大写字母经过偏移后会恰好回到原来的位置,即大写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ 经过偏移后会保持不变。
输入格式
第一行包含一个正整数 n。
输出格式
输出在偏移量为 n 的情况下,大写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ 移位替换后的结果。
数据范围
对于全部数据,保证有 1 ≤ n ≤ 100。
样例输入1
text
31
样例输出1
text
DEFGHIJKLMNOPQRSTUVWXYZABC1
样例解释
当偏移量是3时,大写字母 A 替换成 D,Z 替换成 C,整体替换如上。
解题思路
查看解题思路
- 理解偏移规则:大写字母循环右移 n 位,超出 'Z' 回到 'A'。
- 计算新位置:使用
(i + n) % 26得到新字母索引。 - 逐字符输出:从 'A' 开始依次输出26个字母。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限参考程序
查看参考程序
cpp
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;
cin >> n;
for(int i = 0; i < 26; i++){
int j = (i + n) % 26;
char ch = 'A' + j;
cout << ch;
}
cout << "\n";
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限2. 编程题:寻找倍数
题目描述
小杨有一个包含 n 个正整数的序列 A = [a₁, a₂, ..., aₙ],他想知道是否存在 i (1 ≤ i ≤ n) 使得 aᵢ 是序列 A 中所有数的倍数。
输入格式
第一行包含一个正整数 t,代表测试用例组数。
接下来是 t 组测试用例。
对于每组测试用例,一共两行。其中,第一行包含一个正整数 n;第二行包含 n 个正整数,代表序列 A。
输出格式
对于每组测试用例,如果存在 i (1 ≤ i ≤ n) 满足对于所有 k (1 ≤ k ≤ n) aᵢ 是 aₖ 的倍数,输出 Yes,否则输出 No。
数据范围
对于全部数据,保证有 1 ≤ t ≤ 10, 1 ≤ n ≤ 10⁵, 1 ≤ aᵢ ≤ 10⁹。
样例输入1
text
2
3
1 2 4
5
1 2 3 4 51
2
3
4
5
2
3
4
5
样例输出1
text
Yes
No1
2
2
样例解释
第一组中 4 是 1、2、4 的倍数,故输出 Yes;第二组无此数,故输出 No。
解题思路
查看解题思路
- 找出最大数:序列中的最大数才有可能成为所有数的倍数。
- 验证倍数:检查最大数是否能整除序列中每一个元素。
- 输出结果:全部整除输出 Yes,否则输出 No。
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限参考程序
查看参考程序
cpp
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int a[N];
int main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
int t;
cin >> t;
while(t--){
int n;
cin >> n;
long long x = 0;
for(int i = 1; i <= n; i++){
cin >> a[i];
x = max(x, (long long)a[i]);
}
int fl = 0;
for(int i = 1; i <= n; i++){
if(x % a[i] != 0){
fl = 1;
break;
}
}
if(fl) cout << "No\n";
else cout << "Yes\n";
}
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
登录后查看内容
此内容需要登录后才能查看,请先登录您的账户。
1级权限
需要 1 级或以上权限